[SAP ABAP开发技术总结]几个小技巧

 

10.1.     READ TABLE...WITH KEY可使用OR条件或其他非“=”操作符

READ TABLE...WITH KEY... 后面不能接OR条件操作符,也不能使用其他非等于的比较操作符,因原是该语句即使在查询出多条时也只取第一条,所以限制了 WITH KEY 后面条件使用。下面是错误的语法:

READ TABLE it_tab WITH KEY k1 = 'C' OR k2 = 'C'.

可以使用下面方式代替:

LOOP AT il_item_status WHERE k1 = 'C' OR k2 = 'C'.
 
...
 
EXIT.
ENDLOOP.

10.2.     SELECT SINGLE ... WHERE...无法排序问题

SELECT SINGLE ... WHERE ...

使用SINGLE是表示根据表的关键字来查询,这样才能确保只有一条数据,所以当使用SINGLE时,语法上不能再使用ORDER BY语句(因为没有必要了),如果查询时不是根据关键字来查询,且查询时先排序再取一条时,我们只能使用另一种语法:

SELECT * FROM  tj02t INTO CORRESPONDING FIELDS OF TABLE gt_result UP TO 1 ROWS  

WHERE SPRAS = 'E' ORDER BY ISTAT.

如果是取某个最大值或最小值,则可以使用聚合函数更简洁:

 SELECT MIN( edatu ) INTO (g_tabcon_mps_wa-edatu)FROM vbep
     
WHERE vbeln = ztab_mps-vbeln AND posnr = ztab_mps-posnr
.

10.3.     当心Where后的条件内表为空时

SelectIfDelete 内表、readlook at内表语句中的Where条件中如果使用的Range是一个空的条件内表  xx IN range恒为真那么 xx NOT IN range则恒为假

注:不会像FOR ALL ENTRIES那样忽略其他的条件表达式其他条件还是起作用

10.4.     快速查找SO所对应的交货单DNPO

快速查找SOVBAP)所对应的DNLIPS):虽然可以通过vbap-vbeln = lips-vgbel AND vbap-posnr = lips-vgpos来关联查找,但LIPS-VGBELLIPS-VGPOS非主键,查找起来非常慢(但根据DN来查找所的SO是很快的,因为此时为主键查找)但可以通过VBFA单据流表来查找DN,这样会非常快,因为这是根据主键来查找的:

vbfa~vbelv = vbap-vbeln AND  vbfa~posnv = vbap-posnr AND vbfa~vbtyp_v ='C' AND vbfa~vbtyp_n = 'J'

另外,根据SO查找PO时,可以根据EKKN-VBELN= VBAP-VBELN AND EKKN-VBELP=VBAP-POSNRSOPO中间表EKKN里去找,但查找条件为非主键也非索引,所以找起来时很慢,可以通过VBFA单据流表进行查找,因为VBFAvbelnposnn 字段上创建了索引(虽然查询时WHERE从句条件字段不是按主键字段顺序——使用的是后半部分主键,所以用不到主键索引,但是是按非主键索引字段顺序书写,所以还是可以用到索引):vbfa~vbeln = vbap-vbeln AND  vbfa~posnn = vbap-posnr AND vbfa~vbtyp_v ='V' AND vbfa~vbtyp_n = 'C'

10.5.     X类型的C类型视图

" <--> 6C5F
" <--> 6B63
*DATA: x(4) TYPE x VALUE '6C5F'.
DATA: x(2) TYPE x VALUE '6C5F'.
FIELD-SYMBOLS: <c> TYPE c.
"有时将X类型分配给C类型时会出错长度需要是4的倍数所以定义成4的倍数
"即可解决这个问题但有时定义的长度只能是某个特定数所以此时只能使用后面这种方式
"编译时报错误The length of "X" in bytes must be a multiple of the size of
"a Unicode character, regardless of the size of the Unicode character.
*ASSIGN x to <c> CASTING.

"只能先定义一个C类型变量,再将这个C类型变量分配给X类型字段符号,这样就可
"以随便在x类型之间捣腾了,但此时C变量不是X变量的真正视图了(经过了拷贝)
DATA: c(1) .
FIELD-SYMBOLS: <x> TYPE x.
ASSIGN c to <x> CASTING.
<x>
= x.
" 6C5F注:如果输出的是乱码,则是字节序的问题,需写成5F6C(如Windows操作系统中)
WRITE: /(2) c, <x>.
" 6B63注:如果输出的是乱码,则是字节序的问题,需写成636B(如Windows操作系统中)
x = '6B63'.
<x>
= x.
WRITE: /(2) c, <x>.

10.6.     字符串连接:&& 替代 CONCATENATE 

有如将整型(I)与一个字符串(String)进行连接,此时不能直接使用CONCATENATE进行连接,因为CONCATENATE 操作的是字符类型,所以需要将整型转换为字符型后才能使用CONCATENATE 进行连接,但这里需要注意的,当正整型变量转换为字符类型时,符号位会转换为空格,这时使用CONCATENATE 接连得到的字符串可能会多出一个空格;当将整型变量与字符串进行连接时,最好使用 && 操作符,除了直接能连接外,还不会出现多余空格的问题:

DATA: i TYPE i VALUE '10'.
DATA: str TYPE string VALUE 'string'.
DATA: tmp TYPE string.
str
=
i && str.
WRITE: / str.
tmp
= i
.
CONCATENATE tmp str INTO str.
WRITE: / str.

image091

10.7.     Variant变式中动态日期 

报表程序的选择屏幕中,输出条件后可以点击保存按钮,会弹出创建变式的屏幕,如果条件中有日期字段,日期字段可以随着时间变化,日期字段的值也可以动态的变化,如对于每天都要跑的Job报表很有用,每天查询当天。当然也可以通过报表程序的INIT事件里动态获取当前日期,但可能需要修改程序

image092

image093

除用在中Job外,变式还可以用在Tcode

posted @ 2015-02-01 08:21  江正军  阅读(7061)  评论(0编辑  收藏  举报